# 2023 Digital IC Design Homework 3

|                                                                                                                                                                                                                                                                                                                                      |           |     |      | n Homework 3   |     |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|------|----------------|-----|--|
| NAME                                                                                                                                                                                                                                                                                                                                 | 何坤霖       |     |      |                |     |  |
| Student ID                                                                                                                                                                                                                                                                                                                           | N26112445 |     |      |                |     |  |
| Simulation Result                                                                                                                                                                                                                                                                                                                    |           |     |      |                |     |  |
| Functional simulation 100                                                                                                                                                                                                                                                                                                            |           | 100 |      | Gate-level 100 |     |  |
|                                                                                                                                                                                                                                                                                                                                      |           | 100 |      | simulation     | 100 |  |
| Functional                                                                                                                                                                                                                                                                                                                           |           |     |      |                |     |  |
| #(_) # .''. # ['. Congraultaions!!! You past all patterns! Your score is 100. # / / .\/. \ Total use 2171 cycles to complete simulation. #   \                                                                                                                                                                                       |           |     |      |                |     |  |
| Gate-level                                                                                                                                                                                                                                                                                                                           |           |     |      |                |     |  |
| #(_). # .''. # [] Congraultaions!!! You past all patterns! Your score is 100. # / / .\/. \ Total use 2171 cycles to complete simulation. #   \/\_/   # /'\/'\ # /''!''. # /''!''. # /''!''. # ** Note: \$finish : D:/Master shit life/ll1-2/dic2023/HWs/HW3/testfixture.sv(191) # Time: 39078 ns Iteration: 1 Instance: /testfixture |           |     |      |                |     |  |
| Synthesis Result                                                                                                                                                                                                                                                                                                                     |           |     |      |                |     |  |
| Total logic elements                                                                                                                                                                                                                                                                                                                 |           |     | 934  |                |     |  |
| Total memory bits                                                                                                                                                                                                                                                                                                                    |           |     | 0    | 0              |     |  |
| Embedded multiplier 9-bit elements                                                                                                                                                                                                                                                                                                   |           |     | 1    |                |     |  |
| Total cycle used                                                                                                                                                                                                                                                                                                                     |           |     | 2171 |                |     |  |
| Clock width                                                                                                                                                                                                                                                                                                                          |           |     | 18   |                |     |  |

## Flow Summary

<<Filter>>

Flow Status Successful - Wed Apr 19 11:23:46 2023

Ouartus Prime Version 20.1.1 Build 720 11/11/2020 SJ Lite Edition

Revision Name AEC Top-level Entity Name AEC

Family Cyclone IV E Device EP4CE55F23A7

Timing Models Final

Total logic elements 934 / 55,856 (2%)

Total registers 533

Total pins 19 / 325 (6%)

Total virtual pins

Total memory bits 0 / 2,396,160 (0 %)

Embedded Multiplier 9-bit elements 1 / 308 (< 1 %)

Total PLLs 0/4(0%)

## **Description of your design**

我主要拆分成 5 個 state: DATA IN, IN2POST, CAL, OUT, IDLE。

## **Sequential**

#### DATA IN:

跟 clk 把個個 token 存在 infix string 直到遇到 8'd61 ('=') 同時累計 infix\_id,當狀態切換時(輸入 '='),把 idx 給 len。

#### IN2POST:

把存放在 infix string 的值一筆筆拿出來,遇到數字 token 就直接存放到 postfix str,其他運算子根據類別區分 priority。

8'd40('('): 直接存放在 op stack, 更新 in idx 以再下一個 clk 讀取 infix string 數值。

8'd41 ('('): 檢查 op\_stack top 位置有沒有 ')' 沒有就繼續 pop, 同時更新 post str idx ,來求下一個存放位置。

8'd42 ('\*'): 檢查 op stack top 位置有沒有 '\*',沒有就 push 進去 op stack, 有就 pop 出來到 postfix string。

8'd43 ('+'), 8'd45 ('-'): 除了遇到 '(' 其他都要 pop 出來到 post str idx,遇 到就把當前 token push 進 op stack。

也檢查 op idx 有沒有為 0(op stack 是否為 empty),沒有就跟著 clk 一個個 pop 到 postfix string。

最後 op idx 為 0 時把 postfix 長度更新上到 post str len。

## CAL:

取出 postfix\_string 的值,遇到數字就轉換再 push 到 cal\_stack,如果遇到 operator 就 pop 出上面兩個數值再執行對應的運算,再 push 結果回去,值 到 post\_str\_idx 等於 post\_str\_len。

## OUT:

取出 cal\_stack 最下面的值就是運算結果,同時把 valid 設 1 等待 tb 檢查。IDLE:

把 valid 設回 0,同時 reset 一些數值(result, infix\_string, postfix\_string, cal\_stack, op\_stack, inf\_str\_len, post\_str\_len, in\_idx, op\_idx, post\_str\_idx, cal\_idx)。

## **Next State Logic**

初始狀態 DATA\_IN,當遇到 8'd61 ('=') 轉成 IN2POST,其他都 DATA IN。

在 IN2POST 當 (in\_idx < in\_str\_len),就切到 CAL state,其餘繼續轉。

在 CAL 當 (post\_str\_idx < post\_str\_len) 繼續算,其他到 OUT。 OUT 等待 1 cycle,就切到 IDLE,最後回到 DATA\_IN。

Scoring = Area cost \* Timing cost

 $Area\ cost = Total\ logic\ elements + Total\ memory\ bits + 9*Embedded\ multipliers\ 9-bit\ elements$ 

Timing cost = Total cycle used \* Clock width

\* Total logic elements must not exceed 1500.